

# ELEX 7660: Digital System Design

Lab 1

Student Name: Taewoo Kim Student Number: A01284763 Set: T

# **Table of Contents**

| 1    | Screenshot of Waveforms                  | . 3 |
|------|------------------------------------------|-----|
| 2    | Source code of the module                | . 4 |
| 3    | Quartus compilation report               | . 6 |
| 4    | RTL Netlist                              | . 7 |
|      |                                          |     |
| Tal  | ble of Figures                           |     |
| Figu | re 1 – Waveform of bcitid module         | . 3 |
| Figu | re 2 - Waveform of decode2 module        | . 3 |
| Figu | re 3 – Waveform of decode7 module        | . 4 |
| Figu | re 4 – Source code of the decode2 module | . 4 |
| Figu | re 5 - Source code of the decode7 module | . 5 |
| Figu | re 6 - Source code of the bcitid module  | . 6 |
| Figu | re 7 - Quartus compilation report        | . 6 |
| Figu | re 8 – Final RTL Netlist                 | . 7 |

### 1 Screenshot of Waveforms



Figure 1 – Waveform of bcitid module



Figure 2 - Waveform of decode2 module



Figure 3 – Waveform of decode7 module

#### 2 Source code of the module

Figure 4 – Source code of the decode2 module

```
decode7.sv
// Decription: The decode7 module converts any 4 bit number num (0, 1, 2, ...E, F)
              the signals necessary to control the 7-segment display.
// author: Taewoo Kim
// date: Jan 14, 2025
output logic [7:0] leds); // 7-segment LED cathods
       // use case statement to map the input number to the corresponding
       // 7-seg display
       always_comb begin
           case(num)
               4'h00 : leds = 8'h3F;
                                         // display 0
               4'h01 : leds = 8'h06;
                                         // display 1
               4'h02 : leds = 8'h5B;
                                         // display 2
               4'h03 : leds = 8'h4F;
                                         // display 3
               4'h04 : leds = 8'h66;
                                         // display 4
              4'h05 : leds = 8'h6D;
                                         // display 5
               4'h06 : leds = 8'h7D;
               4'h07 : leds = 8'h07;
                                        // display 7
               4'h08 : leds = 8'h7F;
                                         // display 8
               4'h09 : leds = 8'h67;
                                         // display 9
               4'h0A : leds = 8'h77;
                                        // display A
               4'h0B : leds = 8'h7C;
                                         // display b
               4'h0C : leds = 8'h39;
                                         // display C
               4'h0D : leds = 8'h5E;
                                        // display d
               4'h0E : leds = 8'h79;
               4'h0F : leds = 8'h71;
                                        // display F
           endcase
       end
endmodule
```

Figure 5 - Source code of the decode7 module

```
bcitid.sv
// Description: The bcitid module implements a 4x4 bit memory
                that will store the last four digits of our BCIT student ID.
// author: Taewoo Kim
// date: Jan 14, 2025
module bcitid (input logic [1:0] digit, // 2-bit input digit
                output logic [3:0] idnum); // 4-bit output for id #
    // Use case statement to map the input digit to the corresponding
    // student ID number
    always_comb begin
        case (digit)
             2'b11: idnum = 4'h4; // Leftmost digit
             2'b10: idnum = 4'h7; // Third digit
             2'b01: idnum = 4'h6; // Second digit
             2'b00: idnum = 4'h3; // Rightmost digit
        endcase
    end
endmodule
```

Figure 6 - Source code of the bcitid module

## 3 Quartus compilation report



Figure 7 - Quartus compilation report

# 4 RTL Netlist



Figure 8 – Final RTL Netlist